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ing methods is described. 
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BLOCK CODED MODULATION SYSTEM 

Background of the Invention 
This invention relates to high-speed data 
transmission over band-limited channels, such as.'v 
telephone lines. . 
5 Modulation systems for such channels commonly 

use two-dimensional carrier modulation, generically 
called double-sideband-quadrature-carrier (dSB-QC) 
modulation. Such modulation systems are discussed, . for 
example, in U.S. Patent 3,887,768 (Forney/Gallag^r ) , 

10 incorporated herein by reference, which also shows an 
implementation of such a system. 

Conventional DSB-QC systems are used.tp send an 
integer number (N) of bits In each modulation interval 
of T seconds in a nominal bandwidth of 1/T Hz.. ." For 

15 example, some telephone line modems send 4 bits per 
modulation interval of 1/2400 sec. within a nominal 
bandwidth of 2400 Hz, thus achieving a. 9600 bits \p.er • 
second (bps) data transmission rate. Modems for sending 
6 bits per modulation interval to achieve 14,400 ; bps in, • 

20 a nominal 2400 Hz bandwidth are also; available^ V 

'Stich DSB-QC' systems use' signal cons te'rilafc ions \ 
of 2 signals for sending N bits per modulation f>f; ;.. . : 
interval. A family of such constellations with. signals 
arranged on a regular rectangular grid is described in 

25 Campopiano and Glazer, "A Coherent Digital Amplitude and 
Phase Modulation Scheme," IRE Transactions on c : , /. 
Communication Systems, Vol. CS-9, pp. 90-95, MaV^h 1962, 
incorporated herein by reference. 

Fig. 1 shows the arrangement of signals; in the 

30 Campopiano and Glazer constellations and the but ex : . 

boundaries of those constellations for values o£;..,$T from 
4 through 8. Table I shows the so-called "required 
signal r to-noise ratio" P (defined in Campopiano . et al. 
and in. the Forney/Gallager patent) for the 
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constellations of Fig* 1. Each unit increase in N 
corresponds to an increase in required signal-to-noise 
ratio of about a factor of two or 3-0 decibels (dB) . 



Table I (Campopiano and Glazer) 

5 N S T (dB) 

4 16 10 10.0 

5 32 20 13.0 

6 64 42 16.2 

7 128 .82 19.1 
10 8 256 170 22.3 

N = number of bits sent per modulation interval 
S = number of signals in signal constellation 
P = required signal-to-noise ratio 
(dB) = *P measured in decibels 

15 For higher transmission speeds, so-called coded 



modulation techniques can provide improved resistance to 
noise and other channel impairments; that is, they can 
provide a reduction in required signal-to-noise ratio, 
or a so-called "coding gain".* 
20 In such coded systems, to send N bits per 

modulation interval, signal constellations having more 
than 2 N signals are used, and coding is used to 
introduce dependencies between modulation intervals so 
that the set of available signals from which a signal 
25 point can be selected in one modulation interval depends 
in general on the signal points selected for other 
modulation intervals. 

In one coding technique for getting a coding 
gain (disclosed in Csajka et al, O.S. Patent 4077021, 
30 and Ungerboeck, "Channel Coding with Multilevel/Phase 
Signals," IEEE Transactions on Information Theory, Vol. 
IT-28, pp. 55-67, January, 1982), the N bits appearing 
in each modulation interval are individually mapped into 
signal points selected from a constellation of 2 N+ ^ 
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signals. The signals in the constellation are organized 
into subsets such that the minimum distance between two 
signals belonging to one subset is greater than the 
minimum distance between any two signals in the 
5 constellation. The selection of the signal point for 
each N input bits is made to depend, in part, on the 
historical sequence of all previously selected siignal 
points, as represented by the state of a finite state 
device in the encoder. This so-called trellis, coding 

10 effectively permits only certain sequences of signal 
points to be transmitted, and the coded historical 
information carried by ever^y signal point is exploited 
at the receiver by a maximum likelihood sequence. * 
estimation technique (e.g., one based on the Viterbi 

15 algorithm, as described in Forney, "The Viterbi 
Algorithm," Proceedings of the IEEE, Vol. 61, pp. 
268-278, March, 1973, incorporated herein by; reference). 

A coding gain can also be realized using a 
block coded modulation system in which blocks of ;;n -input 

20 bits are sent in m modulation intervals , . so. t^a^t^N^n/m. . 

bits are sent per modulation interval. For each, block,: 

m signal points are selected from a constellation having 
N 

more than 2 signals, a process which is equivalent to 
mapping each block into a code word selected from an 

25 available code word set of 2 n code words arranged in 

2m-dimensional space (called simply 2m-space) , with the' 
2m coordinates of each code word, taken two at a =time> • 
defining the respective pair of coordinates in ■ 
two-dimensional space of the m signal points to bfe 

30 selected. The code word set from which the code word f 
for any block may be drawn is independent of the- signal 
points selected for any other block. At the receiver , 
the decisions on which signal points were sent aire based 
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on the received signal points for each block (the 
so-called received word) , preferably using maximum 

likelihood decoding. 

One method of block coding involves using a 
5 code word set arranged on a finite portion of a densely 
packed infinite geometrical lattice in 2m-space ; see, 
for example, Conway and Sloane, "Fast Quantizing and 
Decoding Algorithms for Lattice Quantizers and Codes," 
IEEE Transactions on Information Theory, Vol. IT-28, pp. 
10 227-232, March 1982, and the references cited therein, 
incorporated herein by reference. A representative 
system of this type is disclosed in "Block Coding for 
improved Modem Performance," a Canadian contribution 
(Com XVII-No. 112) to Study Group XVII of the 
15 international Telegraph and Telephone Consultative 

Committee (C.C.I.T.T.) , March 1983, incorporated herexn 
by reference, which describes an 8-space code for 
sending 4 bits per modulation interval with an 
asymptotic coding gain of 3.4 dB over the uncoded 
20 Campopiano and Glazer 16-signal constellation (defined 
by the N=4 boundary in Fig. 1) - . 

Summary of the Invention 
The invention includes a family of block coded 
modulation systems of progressively greater complexity 
25 exhibiting progressively greater coding gain over 

uncoded systems. 

In general, in one aspect the invention 
features, in such block coded modulation systems, the ^ 
improvement in which the signal constellation includes 

30 groups having equal numbers of signals, and the encoder 
is arranged so that the group from which at least one 
signal point for a block is drawn depends on the group 
from which at least one other signal point for the block 
is drawn, whereby a coding gain over uncoded systems is 

35 achieved. 
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In preferred embodiments, the signals are 

arranged (e.g., on a rectangular grid) so that the 

minimum squared distance between two signals belonging 

to the same group is greater than (e.g., twice the 

5 distance) between two signals belonging to different 

groups; the signal points are two dimensional, the code 

words are 2m-dimensional , m being the number of signal 

points corresponding to each code word, and each block 

of digital data has mN bits; each block comprises a 

10 plurality of bits, and the groups from which the signal 

points for the block are drawn are determined by a 

single bit of the block; N is an integer, m is an even 

integer no smaller than 2, and the constellation has 
N 

1.5x2 signals; N=r+l/2 f r being an integer, m is no 

15 smaller than 2, and the constellation comprises 2 r+ * 
signals; the encoder is further arranged so that m-1 
signal points for each block may be drawn from among all 
signals in the constellation, and the one remaining 
signal point for the block is drawn from a group, that 

20 depends (e.g., by means of a single-par ity-check code or 
a state- transition trellis) on the groups f rom *:yrhich the 
m-1 signal points are drawn; m is 2; and N is 4 or '4 1/2. 

In other embodiments, the groups each have 
subsets having equal numbers of signals, and the encoder 

25 is further arranged so that the subset from which at 

least one signal point for the block is drawn depends on 
the subset from which at least one other signal point 
for the block is drawn; the signals are arranged (e.g., 
on a rectangular grid) so that the minimum squared 

30 distance between two signals belonging to one subset is 
greater than (e.g., twice the distance) between two 
signals belonging to different subsets within the same 
group; .the subsets from which the signal points for a 
block are drawn are determined based on a plurality of . 
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bits representing less than all of the digital data of 

the block; N is an integer, m is at least 4, and the 

N+l 

constellation has 2 said signals; N=r+l/2, r being 
an integer, m is an even integer no smaller than 4, and 

5 the constellation has 1.5x2 r+1 signals; the encoder is 
further arranged (e.g., by means of a 
single-parity-check code- a Hamming code, or a 
state-transition trellis) so that one signal point for 
each block may be drawn from among all signals in the 
10 constellation, ra-2 of the signal points are drawn from 
groups that depend on the group from which that one 
signal point is drawn, and the single remaining signal 
point for the block is drawn from a subset that depends 
on the subsets from which the one signal point and the 

15 m~2 signal points are drawn; m is 4; and N is 4. 

In other embodiments, the subsets each comprise 
classes having equal numbers of signals, and the encoder 
is further arranged so that the class from which at 
least one signal point for the block is drawn depends on 

20 the class from which at least one other signal point for 
the block is drawn; the minimum squared distance between 
two signals belonging to one class is greater than 
between two signals belonging to different classes 
within the same subset; each block has a plurality of 

25 bits, and the classes from which the signal points for 
the block are drawn are determined based on a plurality 
of bits representing less than all of the digital data 
of the block; ra is 8; N is an integer and the constel- 
lation has 1.5x2 n+1 signals; N=r+l/2, r being an 

30 integer, m is 8, and the constellation comprises 2 
signals* 

In other embodiments, the classes each comprise 
subclasses having equal numbers of signals, and the 
encoder is further arranged so that the subclass from 
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which at least one signal point for the block is drawn 
depends on the subclass from which at least one other 
signal point for the block is drawn; the minimum squared 
distance between two signals belonging to one subclass 

5 is greater than (e.g., twice the distance) between two 
signals belonging to different subclasses within the 
same class; m is 12; N is an integer and the 
constellation has 2 N+2 signals; the subclasses from 
which the signal points for the block are drawn are 

10 determined by the encoder based on a Golay code applied 
to at least one of the bits; m is 12 and N is 4; and* the 
subclasses from which the signal points for the block are 
drawn are determined based on a plurality of bits 
representing less than 'all of the digital data of the 

15 block. 

In other embodiments, there are means for 
selecting at least one signal point of a block on the 
basis of less than all digital data in the block; the 
constellation has quadruplets each having four signals 
20 located at the same distance from the origin but 

separated by 90° intervals about the origin, the digital* 
data comprises bits, and at least two of the bits are 
quadrantally differentially encoded; the four signals 
belonging to each quadruplet are drawn from four 
25 different subsets; there is also a decoder arranged to 
decide which code word was sent based on maximum 
likelihood sequence estimation in accordance with the 
Viterbi algorithm; there is a demodulator having a 
decoder arranged to. make tentative decisions about which 
30 signal point was sent prior to final decoding of all of 
the received signal points for a block, and the 
demodulator comprises adaptive control circuitry 
arranged to be responsive to the tentative decision; the 
signal points for each code word are drawn from the same 
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group; the decoder is arranged to decide which code word 
was sent by first making a separate tentative decision 
based on code words whose signal points are drawn from 
each group, and thereafter a final decision based on the 

5 separate tentative decisions; selection of signal points 
for a block depends on a single-parity-check code based 
on at least one of the bits of the digital data; and the 
decoder is arranged to decide which code word was sent 
by first making a tentative decision as to each signal 
10 point in the code word without regard to whether the 
parity check is satisfied, and accepting the tentative 
decisions as the final decision, either without changes 
if the parity check is satisfied, or after changing the 
least reliable one of the tentative decisions if the 

15 parity check is not satisfied. 

In another aspect, the invention features, in a 
modulation system for sending a block of digital data 
bits over a band-limited channel using a plurality of 
modulation signal points drawn from a two-dimensional 

20 constellation of available signals, the improvement in 
which the constellation has a plurality of inner 
signals, and a plurality of outer signals further from 
the origin than the inner signals, one bit of the 
digital data determines whether any of the plurality of 

25 signal points will be drawn from the outer signals, and 
if an outer signal will be drawn, at least one other bit 
of the digital data determines which of the plurality of 
signal points will be an outer signal point. 

In preferred embodiments, there are 2 fc signal 

30 points, the digital data comprises at least t+1 bits, 
there are S inner signals and 2 -t S outer signals, and 
t bits determine which signal point will be an outer 
signal point? t=l; the block has 2N+1 bits and S is 
2 , N being an integer; N-l of the bits determine 
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which outer signal is drawn, and N bits determine which 
inner signal is drawn; N is 4; t is 2; each block has 
4N+1 bits and S is 2 N , N being an integer; and N-2 of 
the bits determine which outer signal is drawn and N 
5 bits determine which inner signal is drawn. . 

The 4-space f 8-space, 16-space, and 24-space 
modulation systems of the invention respectively exhibit 
asymptotic coding gains of about 1.5, 3.0, 4.5, and 6.0 
dB over uncoded systems that send the same number of 

10 bits per modulation interval through the same nominal 
bandwidth using DSB-QC modulation. The block coded 
systems of the invention are slightly inferior in 
performance to the best known prior art schemes (e.g., 
about .2 dB and .4 dB worse for 4-space and 8-space 

15 systems, respectively), but have substantial advantages 
in implementation. The invention uses constellations 
having relatively small numbers of signals. The 
encoding techniques are economical, simple, and easily 
implemented. Encoding delay is reduced because early 

20 signal points selected for a given block can be sent 
before encoding of the block has been completed. 
Decoding delay is small because received signal points 
can be finally decoded as soon as all signal points for 
a given block have been received. Useful tentative 

25 decoding decisions can be made even sooner. 

Non-integral numbers of bits per interval can be sent. 
Quadrantal differential encoding can be used to improve 
immunity to phase hits. Economical, simple, and easily 
implemented decoding techniques are made possible. 

30 Other advantages and features of the invention 

will be apparent from the following description of the 
preferred embodiment, and from the claims. 
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Description of the Preferred Embodiment 
We first briefly describe the drawings. 

Drawings 

Fig. 1 is a diagram of a family of five prior 
5 art signal constellations. 

Fig. 2 is a block diagram of modem apparatus- 
Fig. 3 is a diagram of a signal constellation 
in accordance with the preferred embodiment. 

Fig. 4 is a block diagram of the signal 
10 selection logic for the constellation of Fig. 3. 

Fig- 5 is a table showing the correspondence 
between input bits and signal subsets- 
Fig. 6 is a state-transition diagram (trellis) 
* for use with the constellation of Fig. 3. 
25 Fig. 7 is a diagram of a family of four signal 

constellations in accordance with an alternate 
embodiment. 

Figs. 8, 12, 15, 17, and 20 are block diagrams 
of signal selection logic in accordance with alternate 
20 embodiments. 

Figs. 9, 10, 11, 14, 16, and 19 are diagrams of 
signal constellations in accordance with alternate, 
embodiments. 

Figs. 18 and 21 are diagrams of the 
25 relationships of signal quadruplets in the 

constellations of Figs. 16 and 19, respectively. 

Figs. 13, 22, and 23 are trellises for use with 
alternate embodiments. 

In the following section, the preferred 
30 embodiment (an 8-space system sending 4 bits per 

modulation interval and achieving an asymptotic coding 
gain of 3.0 dB) is described first. Alternative 
embodiments thereafter described are other decoding and 
encoding techniques for 8-space block coded modulation 
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systems; 8-space block coded systems for sending any 
integral number of bits per modulation interval; 
multidimensional signal structures for sending a 
non-integral number of bits per modulation interval 
5 (useful in both coded and uncoded systems); 4-space, 
16-space, 24-space, and 2m-space block coded systems; 
and other embodiments. 
Structure and Operation 

In the preferred embodiment (an 8-space block 

10 coded modulation system for sending 4 bits per 

modulation interval), a block of 16 bits is sent in each 
4 modulation intervals using a signal constellation 
having 32 signals. 

Referring to Fig. 2, in transmitter 10 the bits 

15 appearing in an input bit stream 12 are grouped by 
serial/parallel converter 14 into 16-bit blocks 16 
(i.e., n=16). Each block 16 is encoded by signal point 
selection logic 18 into a sequence of four (i.e., m=4) 
2-dimensional signal points 20 (which are then used for 

20 conventional DSB-QC modulation by modulator 22 for 
transmission over channel 24) . 

Referring to Fig. 3, the signal points are 
selected from a two-dimensional signal constellation 30 
having 32 signals (i.e., twice the number of signals 

25 (16) needed for uncoded modulation at 4 bits per 

modulation interval, as with the signal constellation 
shown within the N=4 boundary of Fig. 1). The 32 
signals are arranged in a rectangular grid with integer 
coordinates, each signal point having one odd and one 

30 even coordinate (in an arrangement like the Campopiano 
and Glazer constellation shown within the N=5 boundary 
of Fig. 1, but rotated by 45°) and are divided into four 
disjoint subsets (A Q , A.^ B Q , B^) each having 
eight signals. The four subsets A n , A 1 , B n , B, 
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are arranged in two groups (A, comprising subsets A Q 
and A x , and B, comprising B Q and B^) of two 
subsets each. The arrangement of signals in the subsets 
and groups is such that the minimum squared distance 

5 (d 2 =2) between any two signals on the plane (e.g., 

between an A signal and a B signal) is smaller than the 
minimum squared distance (2d Q =4) between any two 
signals in one group (e.g., between an A Q signal and 
an Aj^ signal) , which is in turn smaller than the 

10 minimum squared distance (4d Q =8) between any two 

signals in the same subset (e.g., between an A Q signal 

and another A Q signal). 

Signal selection logic 18 is arranged to 
select, for each block of input bits, a sequence of four 

15 signal points which are interdependent, i.e., the signal 
group and/or subset from which at least some of the 
signal points for a given block may be selected depends 
in part on at least one of the other signal points 
selected for that block. The code word set from among 

20 which the code word for a given block may be drawn is 
independent of the signal points selected for any other 

block. . . 

Each of the 32 constellation signals can be 
uniquely specified by a total of 5 bits: one bit naming 
25 the group from which it is taken, one bit naming the 

subset within that group, and three bits naming which of 
the eight signal points within the named subset is to be 
selected. Thus the four signal points for a block could 
be uniquely specified by a total of 20 bits. However, 
30 the block has only 16 input bits on which to base the 

selections . 

Referring to Fig. 4, the group, subset, and 
signal- point selection information needed to select each 
of the four signal points for each block is derived from 
35 the 16 input bits (b^-bj^) as follows. 
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Group selector 32 uses bit (called the 
group bit) to determine the one group from which all 
four signal points for a given block is to be drawn, 
(The designation group^ refers to the group from which 

5 the first signal point is selected; and so on.) 

Group^ through group^ are therefore always the same 
group for a given block. For example, if b^ = 0 all 
four signal points would be selected from group A; if 
b^=l, all would* be from group B. 

10 Subset .selector 34 uses bits b 2/ b 3 , and 

b. to determine from which subsets of the selected 
4 

group each of the four signal points is to be drawn. 
Bits b 2 r b 3 , and b 4 respectively determine _ . 

subset^, subsetjr.and subset^. For example, in a 

15 block for which the signal points are from group A, if 
b 2 =0 the first signal point would be selected from 
subset Aq, otherwise (if b 2 =l) from A^ Subset 4 
is a parity bit generated by subset selector 34 such 
that bits b 1# b 2 , b 3 and the parity bit (called 

20 subset bits) include an even number of 1 bits. Thus* the 
subset bits can be viewed as coded bits derived by a 
(4, 3) single-parity-check code from the input bits 
b 2 -b 4 . The remaining bits ( b 5~ b ig) taken three 
at a time (called signal point bits) specify which 

25 particular four signal points (signal points-signal 
pointy) are to be drawn by signal point selector 36 
from the sele ted 8-point subsets. Thus group selector 
32 and subset .selector 34 assure that the group from 
which at least one of the signal points for a given 
30 block is selected depends on the group from which at 
least one of the other signal points for the block is 
selected (thereby reducing, after the first signal 
point,* the number of groups from which later signal 
points for a block can be selected), and to assure that 
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the subset from which at least one of the signal points 
is selected depends on the subset from which at least 
one of the other signal points is selected (thereby 
reducing, after the first signal point, the number of 
5 subsets from which later signal points for a block can 

be selected) . 

Although the signal selection (coding) has been 
explained as the selection of four successive signal 
points from a 2-dimensional signal constellation, it 

10 could also be viewed as an 8-space block ^coded 

modulation technique in which a set of 2 code words 
are arranged on a lattice in 8-space, and coding 
consists of selecting one of the code words for each 
block. The eight coordinates of the selected code words 

15 could then be taken two at a tune to specify the four 
two-dimensional signal points to be used for carrier 

modulation. 

The required signal-to-noise power ratio for 
the 32-point signal constellation of Fig. 3 is P"=10, the 
20 same as for the N=4 signal constellation of Fig. 1. The 
minimum squared distance between code words in 8-space 
is 8, double the minimum squared distance (4) between 
signals in the N=4 Fig. 1 constellation, providing an 
asymptotic coding gain of a factor of 2, or 3.0 db. 
25 That the minimum squared distance between code 

words in 8-space is 8 can be seen as follows. Two 
different code words which have the same group bit and 
the same subset bits must differ in at least one of 
their respective four signal points. Because those two 
30 different signal points must be drawn from the same 
subset, and signal points in the same subset have . a 
minimum squared distance of 8 on the two-dimensional 
plane-, • the two code words in 8-space likewise have a 
minimum squared distance of 8. 
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Similarly, two code words which have the same 
group bit but different subset bits must differ in at 
least two of their subset bits (because the subset bits 
have even parity). At least two of their respective 
5 four signal points must therefore differ in each case by 
a minimum squared distance of 4 (the minimum squared 
distance on the two-dimensional plane between two signal 
points chosen from a given group) for a total minimum 
squared distance of 8. 
10 Likewise, two code words which have different 

group bits differ in all four of their signal points, 
and the minimum squared distance between two signal 
points on the two-dimensional plane is 2 for a total 
minimum squared distance of 8. Thus, in all possible 
15 cases, the minimum squared distance is 8. 

The theoretical coding gain of 3.0 dB is 
partially offset by the effect of the error event 
probability coefficient (see Forney Viterbi article), 
which can be estimated as follows. In 8-space, each 
20 .code word has up to 240 nearest neighbors (16 which have 
the same group and subset bits, 96 which have the same 
group bits but different subset bits, and 128 which have 
different group and subset bits). But because code 
words near the-outer boundary of the code word set have 
25 fewer neighbors, the average code word only has about 
180 near neighbors. The error event probability 
coefficient per modulation interval is therefore of the 
order of 180/4 = 45, corresponding to a fraction of a 
decibel of loss in performance for error probabilities 
30 of interest. 

At the receiver, decoding of the four signal 
points into the corresponding bit stream is optimally 
done by maximum likelihood decoding, i.e., picking the 
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one code word which is most likely to have been sent, 
given the 8-space received word determined by the four 
received two-dimensional signal points. 

For each of the received two-dimensional signal 
5 points f the decoder tentatively finds (by conventional 
slicing in two-dimensional space) the closest (in 
Euclidean distance) signal from the A group and the 
closest signal from the B group to the received signal 
point, noting, on a running basis, which of the 
10 coordinates of the tentatively selected signals for each 
group is least reliable (i.e., has the greatest apparent 
error). The subset bits of the four tentatively 
selected A signals are checked for parity. If parity 
checks, then the four tentatively selected A signals 
15 define the closest code word in. the A group to the 

received word. If parity fails to check, the closest A 
code word is found by changing the least reliable 
coordinate to the coordinate of the next closer A 
signal, which (because of the arrangement of the subset 
20 points in the constellation) will always cause a change 
6£ that signal from an A Q to an A^ signal (or vice 
versa) , and thus yield a code word -of correct parity. 
An analogous slicing and parity checking sequence finds 
the closest B code word to the received word. 
25 The final decoding decision entails choosing 

whether the previously determined closest A code word or 
closest B code word is closer (in overall Euclidean 
distance) to the received coordinates in 8-space. The 
choice may be made by computing the sum of the squared 
30 coordinate differences between each of the two code 
words and the received word and comparing the sums. 

Decoding thus requires only slicing (twice) in 
each coordinate, storing (for A and B code words 
respectively) the location and magnitude of the largest 
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apparent error so far, accumulating the Euclidean 
distances for the best code words from each group, 
checking the parity of each best code word (and changing 
one coordinate in each code word, if needed, thereby 
5 changing the Euclidean distance for that word), and 
comparing the Euclidean distances for the resulting two 
best code words to select the better one. This decoding 
method may be readily and simply implemented (by 
conventional techniques) using a programmable 

10 microprocessor . 

The block coded modulation system can be made 
transparent to 90° phase rotations between the received 
carrier and the transmitted carrier using quadrantal 
differential coding on a block basis. The signal 

15 constellation of Fig. 3 is arranged in quadruplets of 
signals having the same radii but separated by 90° phase 
differences, each quadruplet having one signal from each 
subset, so that a 90° clockwise rotation translates, 
within each quadruplet, the A Q signal to the B Q 

20 signal, the B Q signal to the A x signal, the A 1 
signal to the B 1 signal, and the Bj^ signal to the 
A Q signal; and analogous translations occur for 180° 
and 270° rotations. For example, the signals denoted 37 
in Fig. 3 form such a quadruplet. Referring to Fig. 5, 

25 if each signal's subset and group bits are taken 

together as a 2-bit integer, 90° clockwise rotation of 
any signal corresponds to an increment of 1 (modulo 4) 
in the value of that integer. .Quadrantal differential 
coding can then be accomplished by assigning the same 

30 three signal point bits to all four of the signals 

within each quadruplet, and coding the subset and group 
bits for each signal point in a code word by 
differential four-phase coding, using for example the 
subset and group bits of the last signal point of the 

35 previous code word as the reference. 
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If (x^ x 2 ) denotes the differentially 
encoded subset and group bits of the last signal point 
of the previous code word, and (y^, y 2 ) denotes the 
subset and group bits of a signal point in the current 

5 code word (before differential encoding), then (z 1# 
z 2 ) , the differentially encoded subset and group bits 
of that signal point in the current code word, is 
determined by adding (x^ x 2 ) to (y lf y 2 ) as 
two-bit integers, modulo four. Because z 2 =x 2 ® y 2 r 

10 the same differentially encoded group bit is used for 
all signal points in the block. At the receiver, assume 
that both the previous and the current code words are 
correctly decoded (except for a possible phase rotation 
of an integral multiple of 90°). If the received bits 

15 are denoted (x-^, x 2 ') and (z^ , z 2 ') , then 

(y x , y 2 ) is determined by subtracting {x^ , x 2 ') 
from (z 1 *> z 2 '} as two-bit integers, modulo four. 
The resulting (y x , y 2 ) value will then be correct 
even if both (x^ , x 2 ') and (z^ , z 2 ') have been 

20 advanced by p modulo 4 as a result of a p x 90° phase 
rotation. 

Because decoding of a code word can be finished 
as soon as all four received signal points are 
determined, the decoding delay and error propagation of 

25 this block coding system are strictly limited to four 
modulation intervals. Further, because tentative signal 
point decisions (made before all four signal points have 
been received) are only about 3 dB less reliable than in 
the uncoded 16-signal constellation of Fig. 1, those 

30 tentative decisions may be used to update adaptive 
equalizers and other tracking loops in the receiver 
without even waiting for all four signal points to be 
received. The tentative decisions are made by finding 
the closest signal on the constellation of Fig. 3 to 
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each received signal point, which can be accomplished 
by rotating the coordinates 45° with respect to the 
signal constellation, followed by conventional slicing 
in each of the two rotated coordinates. At the 
5 transmitter, transmission can begin as soon as five bits 
(b^, b2, b(-, bg, b^) have been collected, 
thereby reducing the encoding delay which would exist 
for other kinds of block coding in which all of the bits 
of the block would have to be collected before encoding 
10 could begin. 

Other Embodiments 
Other Decoding and Encoding Techniques for 8-Space Block 
Coded Systems . 

In another embodiment, maximum likelihood 

15 decoding can be accomplished by. applying the Viterbi 
algorithm (in a manner described in Forney's Viterbi 
article, cited above) . 

Referring to Fig, 6, in order to apply the 
Viterbi algorithm, the encoding process can be 

20 illustrated by a finite-length 4-state trellis 40; The 
trel-lLs shows from left to right the state of the 
encoder at five successive times, beginning with a node 
42 reflecting the time immediately before encoding of a 
new block begins and ending with a node 44 reflecting 

25 the time just after the encoding of that block has been 
completed. In between nodes 42, 44 are shown four 
modulation intervals separated by three time instants, 
each such instant being represented by a column of four 
nodes 46 corresponding to the four states which the 

30 encoder can occupy at that instant. Branches 48 from 
each node to the next nodes to its right correspond to 
modulation intervals and reflect transitions of the 
state *of the encoder which can occur as a signal point 
is selected. Each branch 48 is labeled with a letter to 
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indicate the subset corresponding to the signal point 
associated with that modulation interval. Each node 46 
is marked with a two-bit value, the first bit reflecting 
the group bit for all signal points for that block 
5 (i.e., 0 = A, 1 = B), and the second bit reflecting the 
value'of the accumulated parity check subset bit as of 

that time. 

The encoder begins at a common node 42 
(reflecting that the encoder's state does not depend on 
10 historical information). From node 42 the encoder 
branches to one of four states depending on the group 
and subset bits of the first selected signal point. For 
example, if the first selected signal point is from 
subset A 0 , the next encoder state is at node 50. For 
15 the next two signal points, the. encoder state stays in 
the half of the trellis defined by the group bit of the 
first signal point, but switches states (from one parity 
to the other) in accordance with the transitions shown. 
Only 16 of the 32 signals in the constellation are 
20 available for selection of the second and third signal. 
The transition to the final node 44 is determined by the 
parity state of the encoder (e.g., an Aj_ or B^^ point 
is sent if the parity state is 1, otherwise an A Q or 
B Q point is sent) . Only a subset of 8 of the 32 
25 signals in the constellation are available for selection 
of the fourth signal point, and that subset depends on 
the first three selected signal points. Thus the paths 
through the trellis define the possible combinations of 
subsets from which the sequence of four signal points 
30 for each block can be chosen. 

In decoding each received word, in accordance 
with the Viterbi algprithm, decisions are first made 
(using* conventional slicing in two dimensions, with the 
• coordinate axes rotated 45°) of which of the eight 
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signals in each of the four subsets is closest to each 
received signal point. A branch in trellis 40 
(corresponding to each subset) is then associated with 
the closest signal in its corresponding subset, and the 
5 so-called metric of each branch is the squared distance 
between the received signal point and the corresponding 
closest signal associated with that branch. The 
remaining steps of the Viterbi algorithm decoding 
proceed as described in Forney's Viterbi article, cited 
10 above. A final decoding decision is possible after four 
modulation intervals, at which time all trellis branches 
converge to a single node 44. 

In another embodiment, the input bits may be 
coded (using a Hamming code) into coded bits which are 
15 used to select the subsets from- which the signal points 
may be selected. 

Four bits in each block, b^-b^, rather than 
being used in a group selector and subset selector (as 
shown in Fig. 4) to select the group and subset from 
20 which each signal point is to be selected, are encoded 
into 8 coded bits using the following 

conventional extended (8, 4) binary Hamming code 
(Hamming codes are discussed, e.g., in Berlekamp, 
Algebraic Coding Theory , McGraw-Hill, 1968, incorporated 
25 herein by reference) : 

z l ■ b 2 

z 2 = b 1 ©b 2 

Z 3 = b 3 

2 4 = b l© b 3 
30 z 5 = b 4 

z 6 = b L ©b 4 

2? .= b 2 0b 3 0b 4 

* z 8 = b l© b 2® b 3© b 4 
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which can be generated using, for example, the following 

generator matrix (having minimum Hamming distance 4) : 

01010101 
11000011 

5 00110011 

00001111 

Bits - Zg are taken in pairs to select the 

subsets of Fig. 3 from which the four signal points are 

to be drawn in accordance with the following table: 

10 Bit Pair Subset 

00 A 0 

01 B 0 

10 B 1 

11 _ Ai 

15 The Hamming distance (d H ) b'etween bit pairs is then 

equal to half the mini-mum squared distance between 

2 

signals in the corresponding subsets, i.e., d (A Q , 
B Q ) = d 2 (A Q , B x ) = d 2 (A r B fl ) = d 2 

* A 1' B l^ = 2r corres P° ndin 9 to d H * 00f = d H 

20 (00, 10) = 6„ (U, 01) = d H (11, 10) = 1; and d 2 

(Aq , A 1 ) = d (B Q , B.^} = 4, corresponding to 

d H (00, 11) = d H (01, 10) = 2. 

The minimum squared distance between code 

words in 8-space is then 8. For if two code words* 

25 correspond to different Hamming coded bits z ^- 2 gr 
then these bits differ in at least 4 places, which 
(because the Hamming distance is half the subset 
distance, as just described) implies that the squared 
distance between the code words is at least 8. 

30 Alternatively, two code words corresponding to the same 
Hamming coded bits z ^~ z g have signal points all in 
the same subsets in each modulation interval; in at 
least one interval the signal points must be different, 
and since they belong to the same subset the minimum 

35 squared distance between them is 8. 
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In other embodiments, the selection of the 
four subsets to be used in the four modulation intervals 
can be done by any method (in addition to the three 
already described) which produces minimum squared 
5 distance of 8 between code words (based on the distance 
properties of the subsets in 2-space) . The 12 bits used 
to select the particular signal point for each 
modulation interval (or the original 16-bit block) can 
be arbitrarily transformed. The constellation can be 
10 any signal constellation that can be divided into four 
eight-point subsets with the required distance 
properties, 

8-Space Block Coded Systems for Sending Any Integral 

Number of Bits per Modulation Interval 

15 In other embodiments, any number of bits (N) 

per modulation interval can be sent by using a signal 

constellation on a rectangular grid having 2 N+1 

signals (e.g., constellations such as the ones shown in 

Fig. 1), divided into four equal subsets (each having 
N-l 

20 2 signals) and arranging the signals* so that 

alternate signals fall respectively in groups A and B, 
and alternate signals within each group fall 
respectively in subsets (A Q , A.^ B Q , B 1 ) • Four 
bits of each block of 4N bits are used to select the 

25 four subsets by any method (including those described 

above) which assures a minimum squared distance between 

2 2 
code words of 4d (where d is the minimum 
o o 

squared distance between signals in the constellation) . 

The remaining 4 (N-l) bits are used to select which 
30 signals within the selected subsets are to be sent in 

each interval. 

Table II shows the required signal-to-noise 

ratios" P for values of N from 3 through 7 using the 

constellations of Fig. 1 with S signal points and the 
35 8-space block coding system described above: 
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Table II 



N S P (<3B) 

3 16 2.5 4.0 

4 32 5 7.0 
5 5 64 10.5 10.2 

6 128 20.5 13.1 

7 256 42.5 16.3 



compared witn cne uncoaeu &jbLcma ucaueu j. h ^^-^^ *r 

about 3 dB of coding gain is achievable for any integer 

. N+l 

10 value of N r using a signal constellation of size 2 

N 

rather than 2 • 

Multidimensional Signal Structures for Sending a 
Non-Integral Number of Bits- per Modulation Interval 
In other embodiments , signal systems of 
15 multiple (at least four) dimensions are* used for sending 
a non-integral number (N) of bits per modulation 
interval, where N is of the form N=r+f (r an integer, f 
a fraction between 0 and 1) . Such systems send blocks 
of bits (each block longer than one modulation 
20 interval) , and are efficient for use in uncoded systems 
(as well as coded systems) because their required 
signal-to-noise ratio is only about fx3 dB more than for 
a comparable Fig. 1 signal constellation for sending r 
bits per modulation interval, and because the number of 
25 signals in the constellation is about (l+f)2 r . 

Referring to Fig. 7, signal constellations for 
use in sending N=r+l/2 bits per modulation interval each 
comprise the 2 r signals in the N=r constellation of 
Fig. 1 (called inner signals) plus an additional 2 
30 signals (called outer signals) generally arranged 

further from the origin, on the same grid, and with the 
same symmetries, as the inner signals. 
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To send blocks of 2r + l bits in two modulation 
intervals, a first bit of the 2r+l bits determines 
whether any outer signal is to be sent. If not, the 
remaining 2r bits taken r at a time determine the two 
5 inner signals for the two intervals. If so, a second 
bit determines whether the outer signal will be sent in 
the first or second modulation interval, r-1 bits 
determine which outer signal, and the remaining r bits 
determine which inner signal is 'sent in the other 

10 interval. The average power required to send both 

signal points will be 3/4 the average power required to 
send inner signals (which are sent on average 3/4 of the 
time) plus 1/4 the average power required to send outer 
signals (which are sent on average 1/4 of the time).- 

15 For example, 4 1/2 bits per modulation interval 

(r=4) can be sent in 2 modulation intervals using the 
constellation having 24 signals (within the N=4 1/2 
boundary of Fig. 7) divided into an inner group of 16 
signals, arranged as shown in Fig. 1 (N=4) and an outer 

20 group of 8 signals, with the arrangement of signals 
exhibiting quadrantal symmetry. 

Referring to Fig. 8, in the signal selection 
logic, bit b 1 is used by outer point selector 60 to 
determine whether none or one of the two selected signal 

25 points will be an outer signal. If one will be, then 
bit b 2 is used by selector 60 to determine which 
interval it will be in, and bits t^-bg are used by 
signal point selector 62 to select the outer and inner 
signals as shown in Fig. 8. If neither signal point is 

30 to be an outer signal, then bits b 2 ~b 5 and b g -b g 
are used by signal point selector 62 to select 
respectively the two inner signals. 
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The average power required to send inner points 
is 10. 0, and to send outer points 26.0. The required 
signal-to-noise ratio is therefore 14 (11.5 dB) , which 
is 1.5 dB more than the requirement for sending 4 bits 
5 per interval using the 16-signal constellation of Fig. 1. 

Table III shows the numbers of constellation 
signals S and the required signal-to-noise ratios P for 
sending half-integer numbers N (between 4 1/2 and 7 1/2) 
of bits per interval using this system with the 
10 constellations of Fig. 7: 

Table HI 



N 



(dB) 



15 



20 



4 1/2 -24 14 U.5 

5 1/2 48 28.5 14.5 

6 1/2 96 57 17.6 

7 x/2 192 - 116 20.6 

In other embodiments, any number of bits per 
interval of the form N=r+2~ fc (t an integer) can be 
sent by adding to inner signals (consisting of the 2 
signals in an uncoded signal constellation) , outer 
signals (consisting of 2 r ~ fc signals located as close 
to the origin as possible consistent with maintaining an 
overall rectangular grid exhibiting quadrantal 
symmetry) . The input bits are taken in blocks of 
25 2 fc r+l and determine 2 fc signal points for 

transmission. Of the 2 fc r+l bits in each block, one 
bit determines whether any of the signal points should 
be an outer signal. If so, then t additional bits are 
used to determine in which of the 2 intervals an 
30 outer signal will be sent, r-t bits determine which 
outer signal will be sent, and r (2^1) bits, taken r 
at a time, are used to select the inner signals to be 
sent in the other 2 t ~l intervals. If none of the 
signal points is to be an outer signal, the remaining 
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2 fc r bits, taken r at a time, are used to select the 
inner signals to be sent in the 2 t intervals. The 
required signal-to-noise ratio for such a block coding 
system is about 3 x 2""*" dB greater than for an uncoded 
5 system in which a signal constellation having 2 r 
signals is used to send r bits per interval. 

For example, referring to Fig. 9, to send 4 1/4 
bits per interval, in 17-bit blocks each 4 intervals 
long (r=4, t=2) , a signal constellation having 16 inner 

10 signals and 4 outer signals is used. One input bit 

determines whether any of the four output signal points 
will be an outer signal. If so, two further bits 
determine in which of the four intervals the outer 
signal will be sent, two further bits select that outer 

15 signal, and 12 bits, taken 4 at a time, select the three- 
inner signals. If no outer signal is to be sent, the 
remaining 16 bits, taken 4 at a time, are used to select 
the four inner signals. The required signal-to-noise 
ratio to send 4 1/4 bits per interval is 

20 7/8x10+1/8x26=12 (10.79 dB) or .79 dB more than to send 
4 bits per interval in an uncoded system. (In this 
case, the outer signals might be moved to the axes to 
save a little more power, if maintenance of the grid is 
not required.) 

25 In other embodiments, a system that sends N=r+f 

bits per modulation interval using a constellation 
having S signals can be extended to one sending 
N , =r+f+2~" t bits per interval using a constellation 
having (l+2~ fc )S signals. To the S original signals 

30 are added 2 _t S additional signals (assuming 2~ t S is 
an integer, and a multiple of 4 if quadrantal symmetry 
is to be maintained) . These additional signals are 
further segmented into subgroups in the same proportion 
as in the unextended system; i.e., each subgroup is 
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2~ fc as large as in the unextended system, and can 
therefore be specified by t fewer bits. For example, if 
in the unextended system there are S=l*5x2 r signals 
divided into 2 r inner signals and 2 r ~ 1 outer 
5 signals, then in the extended system the 2~ t S 

additional points are divided into 2 r " fc additional 
inner signals and 2 r ~ t ™ 1 additional outer signals. 

Input bits are grouped into blocks of 
2 t r+2 t f+l bits (assuming 2 fc f is an integer) and 
10 used to determine 2 t signal points. One of these bits 
determines whether any of the additional 2 t S signals 
is to be used; if not, the remaining 2 t (r+f) bits are 
used to determine the 2 t signal points using the 
unextended system; if so, then t bits are used to 
15 determine which interval uses an additional signal and 
the remaining 2 fc {r+f)-t are used to determine which 
signals, using the unextended system, except that in the 
selected interval one of the additional signals is used 
and is selected with t fewer bits because the 
20 corresponding subgroups are all a factor of 2 
smaller . 

In this iterative fashion, systems that send 
N=r+f bits where f is any binary fraction of the form 
f=2" t i+2" t2 +...+2~ tk , t 1 ^:t 2 ^:..^t k 
25 can be built up, with signal constellations of 
S=2 r (l+2" t l )(l+2~ t2 )...(l+2~** ) 
signals (provided that t 1 +t 2 +. - -+t k is less than 
or equal to r, or to r+2 if quadrantal symmetry is 
desired) . 
30 4-Space Block Coded Systems 

In other embodiments, 4-space block coded 
modulation systems send an integer number (N) of bits 
per modulation interval using signal constellations of 
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the type of Fig. 7, or a half-integer number (N=r+l/2) 
bits per interval using constellations of the type of 
Fig. 1. 

To send a half-integer number of bits per 

5 interval, 2r+l bits are grouped into a block which 

determines two signal points from a constellation having 

2 r+ ^ signals. The constellation is divided into two 

groups A and B of equal size, the two groups 

respectively containing alternate signals. For example, 

10 in Fig. 10 a constellation having 32 signals is divided 

into two 16-signal groups. As another example (not 

using a rectangular grid), Fig. 11 shows an 8-signal 

(8-phase) constellation divided into two 4-signal 

groups. The minimum squared distance between signals 

2 * 2 

15 belonging to the same group (d (A,A)=d (B,B)) is at 

least twice as great as the minimum squared distance 

between signals belonging to different groups 
2 2 

(d (A,B)=d Q ). In Fig. 10 (and in any rectangular 

grid structure), d 2 (A, A) =2d 2 (A,B) ; in Fig. 11 

20 d 2 (A,A)=3.4d 2 (A,B) . 

One bit from each block (the group bit) 

determines whether both signal points will be from group 

r 

A or both from group B. The remaining 2 bits taken r 

at a time determine which of the 2 r A points or B 

25 points is selected for each interval. The minimum 

squared distance between code words must be at least 
2 

2d Q , because (a) between two code words that have 

different group bits (e.g., one group A code word and 

one group B code word), there must be a squared distance 
2 2 

30 of at least d (A,B)=d* in each of the two 

intervals, while (b) between two code words with the 

same group bit, there must be a squared distance of at 

2 2^2 
least d (A,A)=d (B,B)-^ 2d Q in one interval. 

However, the power used is only that required for 
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sending r+1 bits per interval uncoded with a minimum 

2 

squared distance of d Q , which is about the same as 
for an uncoded system sending r bits per interval with a 
minimum squared distance of 2d^. Thus r 4-space 
5 coding allows sending r+1/2 bits per interval at about 
the same required signal-to-noise ratio as an uncoded 
system sending r bits per interval. 

An embodiment using the Fig. 10 32-signal 
constellation to send 4 1/2 bits per modulation interval 
10 is as follows. 

Referring to Fig. 12 , in the signal selection 
logic, the first input bit .(b^ is used by group 
selector 40 to determine the groups (groupj^ and . 
group 2 ) from which both signal points will be 
15 selected, input bits b 2 through b 5 are used by 

signal point selector 42 to select signal poin^ from 
the named group, and input bits b g through b g to 
select signal point 2 from the named group. 

The minimum squared distance between code words 
20 is 4, and the required signal-to-noise ratio "P is 10, 
just as for the 16-signal uncoded Fig. 1 constellation. 
Thus 4 1/2 bits per interval can. be sent with the 
4-space coded system at the same P as 4 bits per 
interval uncoded. 
25 At the receiver, the received code word (i.e., 

the two received signal points for each block) may be 
decoded by determining the most likely two A signal 
points to have been sent and the most likely two B 
signal points to have been sent (using 2-diraensional 
30 slicing in each modulation interval), and choosing the 
pair (i.e., the code word) which has the minimum squared 
distance to the received word. 
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In other embodiments, decoding is accomplished 
by making a tentative decision (in each modulation 
interval) of the most likely signal point to have been 
sent in that interval (using two-dimensional slicing 
5 with the two-dimensional coordinates being rotated 45° 
with respect to the signal constellation) . If the 
tentative decisions in both intervals are of signal 
points in the same group, those tentative decisions 
become the final decision. Otherwise, the tentative 
10 decision having the least reliable coordinate is changed 
to the next nearest signal point (which will be from the 
other group), and the new tentative decision becomes the 
final decision. 

In other embodiments, maximum likelihood 
15 decoding can be accomplished by applying the Viterbi 
algorithm. Referring to Fig. 13, the encoding process 
can be characterized by a finite-length 2-state trellis 
that determines the groups from which signal points are 
selected in two successive intervals in a manner 
20 analogous to Fig. 6. In this case Viterbi algorithm 

decoding is essentially equivalent to the first decoding 
method for 4-space codes described above. 

Table IV shows the numbers of signals in the 
constellation and the required signal-to-noise ratios 
25 for sending half-integer numbers (between 3 1/2 and 7 
1/2) of bits per interval using this 4-space coding 
system. 

Table IV 



N S P (db) 

30 3 1/2 16 5 7.0 

4 1/2 32 10 10.0 

5 1/2 64 21 13.2 

6 1/2 128 41 16,1 

7 1/2 256 85 19.3 
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By dividing the groups of signals of the 
4-space block coded system into subsets (in the manner 
previously described), quadrantal differential coding on 
a block basis can be used in the same manner previously 
5 described for the 8-space system. 

To send an integral number N bits per interval 
using 4-space coding,- the signal constellations for 
sending N+l/2 bits per interval described earlier in the 
section headed Multidimensional Signal Structures for 
10 Sending a Non-Integral Number of Bits per Modulation 
Interval , are used. In two dimensions, these 
constellations have 1.5x2 N signals, as shown in Fig. 
7, for example. Because they are based on a rectangular 
grid, they may be divided into A and B groups of equal 
15 size (1.5x2 N ~ 1 signals in each) by assigning alternate 
signals to the two groups. The minimum squared distance 
between signals in the same group is twice the minimum 
squared distance between signals in different groups. 
In coding, one input bit (the group bit) from a block of 
20 2 N input bits determines whether A or B signals are to 
be used in both of two intervals. A second input bit 
determines whether an outer signal is to be used; if 
not, the remaining 2(N-1) bits (taken N-l. at a time) 
determine the two inner signals of the appropriate 
25 group; if so, a third bit determines which interval will 
contain an outer signal, N-2 bits select which outer 
signal of the appropriate group, and the remaining N-l 
bits select the inner signal of the appropriate group in 
the other interval. For the same reasons as before, the 
30 minimum squared distance between code words is 

2d^. The coding gain is about 1.5 dB. Any of the 
previously described decoding methods can be used. 
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To send 4 bits per interval, the 24-signal Fig. 
7 constellation is rotated 45° and divided into A and B 
groups as well as into inner and outer signals , as shown 
in Fig. 14. Input bits are grouped into blocks of 8 
5 bits each and each block determines two signal points. 
Referring to Fig. 15, in the signal selection logic, one 
bit (b 1 ) , the group bit in each block, is used by 
group selector 50 to specify the group from which both 
signal points are to be selected, and a second bit 

10 (b 2 ) is used by outer point selector 52 to specify 
whether one of the signal points should be an outer 
signal. (At most one of the signal points for each 
block may be an outer signal.) If neither signal point 
is to be an outer signal, the remaining 6 (i.e., 2(N-1)) 

15 bits (b--b D ) taken three at a time are used by 

signal point selector 54 to determine which of the eight 
inner signals of the selected group is to be selected 
for each modulation interval. If one signal point is to 
be an outer signal, the third bit, b^, determines 

20 which of the two signal points is to be an outer signal 

and the bits b 4~ b 8 select the outer and inner signal 

as shown in Fig. 15. 

The average power required to transmit inner 

siqnals is P. = 5, and to transmit outer signals 

3 inner 

25 is P =13. On average, half of the time the two 

outer 

signal points will both be inner signals, and the other 

half of the time one will be an inner signal and the 

other an outer signal. The average power required to 

send both signal points for a block is therefore 1/2(2 x 

30 p. ) + 1/2{P. + P" . ) or 14. The 

inner 7 / 1 inner outer 

required signal-to-noise ratio is then 7 (8.45 dB) per 
interval compared with 10 (10 dB) required for sending 
uncoded . signal points using the 16-point signal 
constellation of Fig. 1, a 1.55 dB coding gain. 
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Theoretically, as shown by Conway and Sloane, 
the best known 4-space code for sending 4 bits per 
interval has a required signal-to-noise ratio of 6.75 
(8.29 dB) . The present embodiment which has a required 

5 signal-to-noise ratio of 7 (8.45 db) provides a simpler 
coding system at a cost of only 0.16 db compared with 
the best known code for the same parameters. Further, 
because the code word set has quadrantal symmetry, 
quadrantal differential coding may be used (as described 

10 above) to obtain immunity to phase rotations of 
multiples of 90°. 

Table V shows the numbers of constellation 
signals S and the required signal-to-noise ratios P for 
sending integer numbers N (from 4 to 7) of bits per 

15 interval using this system. 

Table V 



N 



S P (dB) 



20 



4 24 7 8.45 

5 48 14.25 11-54 

6 96 28.5 14.5 

7 192 58 17.6 

It can be seen that a coding gain of about 1.5 
dB is obtained for all values of N with a signal 
constellation only 1.5 times the size of that needed for 

25 an uncoded system. 

Further 8-Space Block Coded Systems 

The 4-dimensional signal structures with 
2-dimensional constellations like those of Fig. 7 can 
also be used in 8-space block coded systems by dividing 

30 the signals into subsets A Qf A^,, B Q , B ± in the 

manner described above. The resulting systems send 
half-integer numbers of bits per modulation interval 
with about 3.0 dB coding gain over the uncoded 
4-dimensional signal structures. Table VI is an 



01 22805 



- 35 - 



extension of Table 


II showing some 


of these 


half-integer 


systems in relation 


to the integer 


systems 


previously 


descr ibed . 










Table VI 






N 


S 


f 


(<3B) 


3 


16 


2.5 


4.00 


3 1/2 


24 


3.5 


5.45 


4 


32 


5.0 


7.00 


4 1/2 


48 


7.125 


8.54 


5 


64 


10.5 


10.22 


5 1/2 


96 


14.125 


11.51 



10 



16-Space Block Coded Systems 

In other embodiments, 16-space block coded 
modulation systems are used to send an integer number N • 

15 of bits per modulation interval using Fig* 7-type 
constellations, or half-integer numbers using Fig. 
1-type constellations. 

The constellation must be further partitioned 
into eight equal-sized classes Agg, Aq^, A^q, 

20 A n , B Q0 , B Q1 , B 1Q , B 1]L , after first being 

divided into equal-sized groups A and B and dividing 
each group into equal-sized subsets Ag, A^, and 
Bq, B^. At each step the division is made by taking 
alternate signals. Furthermore, subsets are divided 

25 into two classes with opposite subscripts; e.g., Ag is 

divided into A Q g and A^, A^ into A Q ^ and A^, 

and so forth. The result is that if the minimum squared 

distance between constellation signals is 
2 2 

d =d (A r B) , the minimum squared distance between 

° 2 . 

30 signals in classes in the same group is 2d Q times 

the Hamming distance (d H ) between their subscripts, 

e.g., d 2 (A 0Q , A Q1 )=2d2; d 2 (A Q0 ,A n ) =4d 2 ; 

and the minimum squared distance between signals in the 
same class is 8d£. Fig. 16 shows the 48-signal 
35 constellation of Fig. 7 rotated 45° and partitioned in 
this way. 
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In coding, one input bit of a block of 8N input 
bits determines the group (A or B) from which all 8 
signal points will be selected. Eleven input bits are 
coded in a conventional (16 , 11) Hamming code (with 
5 minimum Hamming distance equal to 4; see, e.g., 

Berlek amu , cited above) to give 16 coded bits, which are 
taken two at a time to determine the class subscripts 
for each signal point. The remaining 8N-12 input bits 
select which signal points are used; if N is an integer, 
10 by using the 4-dimensional system signal constellations 
of 1.5x2 N ~ X signals and taking the bits 2N-3 at a time 
to determine pairs of signal points as described above; 
if N is a half-integer (N=r+l/2) , then by using 
2-dimensional signal constellations of 2 signals 
15 and taking bits N-3/2=r-l at a time to determine signal 
points from the selected classes. 

The minimum squared distance of such 16-space 
block code words is 8d^. Two code words with 

2 . 

different group bits must differ by at least d Q in 

20 all 8 signal points. Two code words with the same group 

bit but different Hamming coded bits must differ in at 

least four class subscripts, so their squared distance 

is at least 4x2d^. Two code words with the same 

group bit and Hamming coded bits have all signal points 

25 in the same classes, but must have in at least one 

interval two different signal points in the same class, 

2 

which must therefore have squared distance 8d Q . 
The minimum squared distance between code words is 
therefore 8 times (or 9 dB) better than that of the 
30 uncoded constellation, but that constellation could 

without coding send 1 1/2 more bits per interval than it 
can with coding, which is equivalent to about 4.5 dB, so 
the net. coding gain is about 4.5 dB. 
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An embodiment using the Fig. 16 48-signal 
constellation to send 4 bits per interval is as follows. 
Referring to Fig. 17, 32 input bits are used to 
select the 8 output signal points as follows. One bit 
5 is used by group selector 70 to the determine the group 
(A or B) from which all signal points will be selected. 
Eleven bits are coded by Hamming coder 72 using a 
conventional (16,11) extended Hamming code (with Hamming 
distance ^ H = 4) into 16 coded bits. Taken in pairs, 

10 the 16 coded bits are used by class selector 74 to 
specify the subscripts of the classes from which the 
eight output signal points are respectively selected. 
The remaining 20 bits (taken 5 at a time) are used by 
signal point selector 76 to select pairs of signal 

15 points of appropriate classes, where each class 

comprises 6 signals, 4 inner and 2 outer, and selection 
between inner and outer signals is made in the same 
manner as previously described. 

The required signal-to-noise ratio is 3.5625 or 

20 5.5dB, a 4.5dB gain over the uncoded N=4 constellation 
of Fig. 1. 

Table VII shows the number of signals S in the 
constellation and the required signal-to-noise ratio P 
for sending integer and half-integer numbers N (between 
25 2 1/2 and 6 1/2) of bits per interval in blocks of 8 
intervals each, using the 16-space coding system 
described above and the signal constellations of Figs, 1 
and 7, 

Table VII 



35 



N 


S 


P 


(dB) 


2 1/2 


16 


1.25 


1.0 


3 


24 


1.75 


2.5 


3 1/2 


32 


2.5 


4.0 


4 • 


48 


3.56 


5.5 


4 1/2 


64 


5.25 


7.2 


5 


96 


7.13 


8.5 


5 1/2 


128 


8.25 


10.1 


6 


192 


14.5 


11.6 


6 1/2 


256 


21.25 


13.3 
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In the signal constellations for the 16-space 
block coding systems, each signal is a member of a 
quadruplet of signals at the same radius from the origin 
and separated by intervals of 90° about the origin. 
5 (For example, the points marked 60 and 62 in Fig. 16 
form such quadruplets.) Because all such quadruplets 
are of one or the other forms shown in Fig. 18, 
quadrantal differential coding (in the manner previously 
described) can be used with the group bit and an 
10 appropriate one of the class subscript bits (in this 
case the second for A and the first for B,' inverted) in 
place of the group and subset bits used in 8-space 
coding, but otherwise as previously described. _ 
24-Space Block Coded Systems 
15 in other embodiments, 2.4-space block coded 

systems can be used to send an integer number of bits 
per interval using Fig. 1-type constellations, or a 
half-integer number of bits per interval using Fig. 
7-type constellations. 
2o To send N bits per interval, N an integer, a 

constellation of 2 N+2 signals on a rectangular grid 
(such as one of those of Fig. 1) is used. The 
constellation is divided into 16 subclasses A.j k , 
B.- k (i,j,k=0 or 1) by further subdivision of the 
25 classes A... and B defined in the previous section 

by taking alternate signals in accordance with a pattern 
defined below. The minimum squared distance between 
signals in different groups is then d Q , between 
signals in the same group but different subsets is 
30 2d 2 , in the same subset but different classes 
is 4d 2 , in the same class but different sub- 
classes is 8d 2 , and finally between signals in the 

° . 2 
same subclass is 16d Q . 
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Referring to Fig. IS, the 64-signal 
constellation of Fig. 1 has been partitioned into 16 
4-point subclasses (for use with a 24-space block coding 
system). In general, a partition of any 

5 rectangular-grid constellation into subclasses using the 
pattern of subscripts shown in Fig. 19 may be used. 

In coding, one input bit of a block of 12N bits 
determines the group (A or B) from which all 12 signal 
points will be selected. Twelve input bits are coded in 

10 the (24, 12) Golay code (which has minimum Hamming 

distance 8; see, e.g., Berlekamp , cited above) to give 
24 coded bits, which are taken two at a time to give the 
(i, j) subscripts of the subclass from which each signal 
point is to be selected. Eleven input bits determine 

15 the k subscripts for the first 11 points, and the 12th k 
subscript is chosen so that the 12 k subscripts have 
even parity (an even number are equal to 1) for A code 
words and odd parity for B code words. The remaining 
12N-24 bits are taken N-2 at a time to select one of the 

20 2 N ~ 2 signals of the selected subclass for each of the 

12 intervals. 

With this construction, the minimum squared 

2 2 

distance between code words is 16d Q , where d Q 

is the minimum squared distance between signals in the 

25 constellation. This is 12 dB better than the uncoded 
constellation having 2 N+2 signals, but that 
constellation without coding could send 2 bits per 
interval more than with this coding, which is equivalent 
to about 6 dB, so the net coding gain is about 6 dB. 

30 One embodiment, using the Fig. 19 constellation 

to send 4 bits per interval, is as follows. Referring 
to Fig. 20, 48 input bits are used to select 12 output 
signal points as shown. One bit is used by group 
selector 80 to determine the group (A or B) from which 



01 22805 



- 40 - 

all signal points will be selected. Twelve bits are 
coded by Golay coder 82 using a conventional (24, 12) 
Golay code (with Hamming distance d H =8) into 24 coded 
bits. Taken in pairs, the 24 coded bits are used by 
5 class selector 84 to specify the (i, j) subscripts of 
the 12 signals to be selected. Eleven bits and the 
group bit are used by subclass selector 86 to specify 
the k subscripts of the 12 points, with 11 subscripts 
equal to the corresponding bits, and the 12th subscript 
10 a parity check on these 11 bits plus the group bit. The 
remaining 24 bits, taken two at a time, are used by 
signal point selector 88 to select one of the four 
signals in each selected subclass. • _ 

The required signal-to-noise ratio with this 
15 system is 2.625 or 4.2dB, 5.8dB better than with the 
uncoded N=4 constellation of Fig. 1. 

Table VIII shows the numbers of signals in the 
constellation and the required signal-to-noise ratios P 
for sending integer numbers N (between 2 and 6) of bits 
20 per interval in blocks of 12 intervals, using the 
24-space coding described above and the signal 
constellations of Pig. 1. (The constellations of Fig. 7 
could be used to send half-integer numbers of bits per 
interval with similar coding gain.) 
25 Table VIII 

N S I ±311 

2 16 -625 -2.0 

3 32 1-255 1.0 

4 64 2.625 4.2 
30 5 128 5.125 7.1 
30 g 256 10.625 10.3 

In the signal constellations for these 24-space 
block coded modulation systems, each signal is a member 
of a quadruplet of signals of the same radius and 
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separated by phase intervals of 90°. (For example, the 
signals marked 90, 92, 94, and 96 in Fig. 19 form such 
quadruplets, respectively.) All such quadruplets are of 
one of the four types shown in Fig. 21, and therefore 
5 quadrantal differential coding (in the manner previously 
described) can be used with the group bit and an 
appropriate subscript bit (in this case the first for A; 
and the second for B, inverted) in place of the group 
and subset bits used in 8-space coding, but otherwise as 
10 previously described. 

Block Coded Systems of Other Numbers of Dimensions 

In other embodiments, block coded systems in 
2m-space can be derived from the 4-space and 8-space 
block coded systems. 
15 The 4-space system can be extended to a 

2m-space system that sends N-l/m bits per interval or 
mN-1 bits per block (for any m greater than or equal to 
2) if N is an integer, or for any even m greater than or 

equal to 2 if N=r+l/2 is a half-integer number. In the 

N - 

20 former case the signal constellation of size 2 is 
used, and in the latter the constellation of 1.5x2 r 
signals divided into inner and outer signals as 
previously described. In either case the constellation 
is divided -into A and B groups as previously described. 

25 The encoder, is arranged so that in the first m-1 

intervals, either A or B signals may be sent, but in the 
last interval, the group must be constrained to satisfy 
a parity condition (e.g., that the total number of A 
signals be even). For example, the groups may be 

30 selected by a two-state trellis encoder operating 
according to the m-interval trellis of Fig. 22. 
Otherwise selection of signals within the groups is as 
previously described. Decoding may be by the Viterbi 
algorithm. 
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The minimum squared distance between code words 
remains 2d 2 in this system because of the parity 
condition and the fact that the minimum squared distance" 
between signals within the same group is at least twice 
5 the minimum squared distance between signals in 
different groups. However, the number of bits 
transmitted per interval is now only 1/m less than in an 
uncoded system using the same constellation , so that the 
coding gain is approximately 3(l~l/m) dB, which 
10 approaches 3 dB for m large. For example, for m=4, an 
8-space coded modulation system with coding gain of 
about 2,25 dB is obtained. 

The 8-space system "can be extended to a 
2m-space system that sends N bits per interval for any m 
15 greater than or equal to 4 and any integer N, using a 
signal constellation of 2 N+1 signals divided into 4 
equal-sized subsets as previously described. The 
encoder is arranged so that all m points are chosen from 
the same group, the first m-1 points being from either 
20 subset of that group, and the final point being chosen 
from a subset selected to satisfy a parity condition 
(e.g., that the total number of 1 subscripts be even). 
For example, the subsets may be selected by a 4-state 
trellis encoder that operates according to the 
25 m-interval trellis of Fig. 23. Otherwise selection of 
signals within subsets is as previously described. 
Decoding may be done using the Viterbi algorithm using 
the Fig. 23 trellis. 

The minimum squared distance between code words 
30 remains 4d 2 in this system because m is greater 
than or equal to 4, there is a parity condition on 
subsets combined with the between-subset distance 
of 2d 2 , and there is a wi thin-subset distance of 
4d^. The number of bits per interval is N for any 
35 value of m, so the coding gain remains about 3 dB. 
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However, for m greater than 4 the number of near 

neighbors of any code word is reduced since code words 

2 

of the opposite group have distance at least md Q 
and are thus no longer near neighbors, reducing the 
5 error event probability coefficient by about a factor of 
2. 

Other Embodiments 
Other embodiments are within the following 
claims. For instance, the input bits can undergo any 
10 transformation which does not result in loss of 

information (such as scrambling, permutation, or binary 
linear transformations) before being encoded. The 
digital data to be sent can *be in characters other than 
bits. The output signal points or indeed their 
15 coordinates can be arbitrarily permuted without loss of 
. coding gain. The coordinates can be used individually 
in one-dimensional modulation systems (such as single 
side-band or vestigial-sideband modulation systems), or 
in groups of appropriate dimension in multidimensional 
20 modulation systems. Other signal constellations 

(including ones not based on rectangular grids) can be 
used provided that their signals can be partitioned into 
equal-sized groups (subsets, classes, subclasses) having 
at least approximately the desired distance properties 
25 described earlier. Any 2m-dimensional orthogonal linear 
transformation of output signal points may be made 
without affecting relative distance properties in 
2m-space. Quadrantal differential coding can be done 
using any method such that 90° rotations of code words 
30 change only quadrantal phase bits, and such phase bits 
are encoded differentially (mod 4) with reference to any 
previously transmitted quadrantal phase bits. 
Multidimensional signal constellations for any binary 
fractional numbers of bits per interval as described 
35 herein, may be used with the block coded modulation 
systems provided that parameters are consistent. 
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CLAIMS 

1. A method for sending digital data over a band-limited 
channel comprising selecting a code word corresponding to 

a plurality of modulation signal points drawn from a con- 
stellation of available signals, the code word being 

5 selected from an available set of said code words on the 
basis of a block of said digital data, and the code words 
belonging to said available set for said block being inde- 
pendent of said signal points corresponding to the code 
word selected for any other said block, characterised in 

10 that said constellation comprises groups having equal 

numbers of said signals, and in that the group from which 
at least one said signal point for said block is drawn 
depends on the group from which at least one other said 
signal point for said block is drawn. 

2. A method according to Claim 1, further characterised 
in that said signal points are two-dimensional, said code 
words are 2m-di mensi onal , m being the number of said signal 
points corresponding to each said code word, and each said 

5 block of said digital data comprising mN bits. 

3. A method according to Claims 1 or 2, further 
characterised in that said signals of said constellation 
are arranged on a rectangular grid. 

4. A method according to Claim 1, further characterised 
in that said signals are arranged in said constellation so 
that the minimum squared distance between two said signals 
belonging to the same said group is greater than between 

5 two said signals belonging to different said groups. 

5. A method according to Claim 4, further characterised 
in that the minimum squared distance between two said 
signal points belonging to the same said group is twice the 
minimum squared distance between two said signal points 

5 belonging to different said groups. 



2 
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6. A method according to any preceding claim, further 
characterised in that each said block comprises a plurality 
of bits, and in that the said groups from which said signal 
points for said block are drawn are determined by a single 
said bit of said block . 

7. A method according to Claim 2, further characterised 
in that m-1 said signal points for each said block are 
drawn from among all said signals in said constellation, 
and the one remaining said signal point for said block is 
drawn from a group that depends- on the groups from which 
said m-1 signal points are drawn. 

8. A method according to Claim 7, further characterised 
in that said group from which said one remaining signal 
point is drawn depends on a single-parity-check code based 
on at least one of said bits. 

9. A method according to Claim 9, further characterised 
in that said group from which said one remaining signal 
point is drawn is determined on the basis of a state- 
transition trellis for said block, 

10. A method according to Claim 2 or any of Claims 3 to 

9 when appendent thereto, further characterised in that N 

is an integer, m is an even integer no smaller than 2, and 

N 

said constellation comprises 1.5x2 signals. 

11. A method according to Claim 2 or any of Claims 3 to* 

9 when appendent thereto, further characterised in that 

N=r+l/2, r being an integer, m is no smaller than 2, and 

r + 1 

said constellation comprises 2 signals. 

12. A method according to any of Claims 2 to 11 , 
further characterised in that m is 2. 

13. A method according to any of Claims 1 to 3, further 
characterised in that said groups each comprise subsets 
having equal numbers of said signals, and in that the sub- 
set from which at least one said signal point for said 
block is drawn depends on the subset from which at least 
one other said signal point for said block is drawn. 

14. A method according to Claim 13, further character- 
ised in that said signals are arranged in said constel- 
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lation so that the minimum squared distance between two 
signals belonging to one said subset is greater than 
between two said signals belonging to different said sub- 
sets within the same said group. 

15. A method according to Claim 14, further character- 
ised in that the minimum squared distance between ttfo said 
signal points belonging to the same said subset is twice 
the minimum squared distance between two said signal 
points belonging to different said subsets. 

16. A method according to any of Claims 13 to 15, 
further characterised in that each said block comprises a 
plurality of bits, and the subsets from which said signal 
points for said block are drawn are determined based on 

a plurality of bits representing less than all of said 
digital data of said block. 

17. A method according to both Claims 2 and 13, further 
characterised in that one said signal point for each said 
block is drawn from among all said signals in said 
constellation, m-2 of said signal points are drawn from 
groups that depend on the group from which said one 
signal point is drawn, and the single remaining said 
signal point for said block is drawn from a subset that 
depends on the subsets from which said one signal point 
and said m-2 signal points are drawn. 

18. A method according to Claim 17, further character- 
ised in that said subset from which said-single remaining 
signal is drawn depends on a single-parity-check code 
based on at least one of said bits. 

19. A method according to Claim 17, further character- 
ised in that said subsets from which said signal points 
for said block are drawn are determined on the basis of a 
state-transition trellis for said block. 

20. A method according to Claim 17, further character- 
ised in that said subsets and said groups from which said 
signal points for said block are drawn are determined 
based on a Hamming code applied to at least one of said 
bits. 
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21 . A method according to any of Claims 13 to 20 

when appendent to Claim 2, further characterised in that 

N is an integer, m is at least 4, and said constellation 
N + 1 

comprises 2 said signals. 

22. A method according to any of Claims 13 to 20 when 
appendent to Claim 2, further characterised in that 
N=r+l/2» r being an integer, m is an even integer no 

r+1 

smaller than 4, and said constellation comprises 1.5x2 
signals. 

23. A method according to any of Claims 13 to 22 when 
appendent to Claim 2, further characterised in that m 

is 4. 

24. A method, according to Claim 13, further character- 
ised in that said subsets each comprise classes having 
equal numbers of said signals, and in that said class from 
which at least one signal point for said block is drawn 
depends on the class from which at least one other said 
signal point for said block, is drawn. 

25. A method according to Claim 24, further character- 
ised in that said signals are arranged in said constel- 
lation so that the minimum squared distance between two 
signals belonging to one said class is greater than 
between two said signals belonging to different said 
classes within the same said subset. 

26. A method according to Claim 25, further character- 
ised in that the minimum squared distance between two said 
signal points belonging to the same said class is twice 
the minimum squared distance between two said signal 
points belonging to different said classes. 

27. A method according to any of Claims 24 to 26, 
further characterised in that each said block comprises a 
plurality of bits, and the classes from which said signal 
points for said block are drawn are determined based on a 
plurality of bits representing less than all of said 
digital data of said block. 

28. A method according to any of Claims 24 to 27, 
when appendent to Claim 7, further characterised in that 
mis 8 . 
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29. A method according to Claim 28, further character- 
ised in that N is an integer and said constellation 
comprises 1.5x2 N+1 said signals. 

30. A method according to Claim 28, further character- 
ised in that N=r+l/2, r being an integer, and said 
constellation comprises 2 signals. 

31. A method according to Claim 24, further character- 
ised in that said classes from which said signal points 
for said block are drawn are determined based on a 
Hamming code applied to at least one of said bits. 

32. A method according to Claim 24, further character- 
ised in that said classes each comprise subclasses having 
equal numbers of said signals, and in that said subclass 
from which at least one signal point for said block is 
drawn depends on the subclass from which at least one other 
said signal point for said block is drawn. 

33. A method according to Claim 32, further character- 
ised in that said signals are arranged in said constel- 
lation so that the minimum squared distance between two 
signals belonging to one said subclass is greater than 
between two said signals belonging to different said sub- 
classes within the same said class. 

34. A method according to Claim 33, further character- 
ised in that the minimum squared distance between two said 
signal points belonging to the same said subclass is twice 
the minimum squared distance between two said signal points 
belonging to different said subclasses. 

35. A method according to any of Claims 32 to 34, further 
characterised in that each said block comprises a plurality 
of bits, and the subclasses from which said signal points 
for said block are drawn are determined based on a 
plurality of bits representing less than all of said 
digital data of said block. 

36. A method according to any of Claims 32 to 35, when, 
appendent to Claim 2, further characterised in that m is 12. 
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37. A method according to Claim 36, further character- 
ised in that N is an integer and said constellation 



38. A method according to Claim 33, further character- 
ised in that said subclasses from which said signal points 
for said block are drawn are determined based on a Golay 
code applied to at least one of said bits, 

39. A method according to Claim 2 or any of Claims 3 to 
38 (other than CI ai ms 1 Ogvr^n appendent to Claim 2, further 
characterised in that N is 4. /i.-^-n 



40. A method according to Claims IQ^pr any Claim appendent 
thereto, further characterised in that N is 4J. 

41. A method according to any preceding Claim, further 
characterised in that said constellation comprises quad- 
ruplets each having four said signals, the signals 
belonging to each said quadruplet being located at the 
same distance from the origin but separated by 90° 
intervals about said origin, said digital data comprises 
bits, and at least two of said bits are quadrantally 
differentially encoded. 

42. A method according to Claim 41, further character- 
ised in that said groups each comprise subsets having equal 
numbers of said signals and said four signals belonging to 
each quadruplet are drawn from four different said subsets. 

43. A method according to any preceding claim, further 
characterised in that decoding is conducted by deciding 
which code word was sent based on maximum likelihood 
sequence estimation i n accordance with the Viterbi 

al gori thm. 

44. A method according to any of Claims 1 to 40, further 
characterised in that all said signal points for each said 
code word are drawn from the same said group. 

45. A method according to Claim 44, further character- 
ised in that decoding is conducted by deciding which said 
code word was sent by first making a separate tentative 
decision based on code words whose signal points are drawn 
from each of said groups, and thereafter making a final 



comprises 2 



N+2 



sai d si gnals . 
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decision based on said separate tentative decisions. 

46. A method according to any of claims 1 to 40, .further 
characterised in that said digital data comprises bits and 
the selection of said signal points for a block depends on 

a single-parity-check code based on at least one of said 
bi ts . 

47. A method according to Claim 46, further character- 
ised in that decoding is conducted by deciding which said 
code word was sent by first making a tentative decision as 
to each signal point in said code word without regard to 

■y whether said parity check is satisfied, and accepting 
said tentative decisions as the final decision, either 
without changes if said parity check is satisfied, or 
after changing the least reliable one of said tentative 
decisions if said parity check is not satisfied. 

48. A method for sending a block of digital data bits 
over a band-limited channel using a plurality of modu- 
lation signal points drawn from a two-dimensional constel- 
lation of available signals, characterised in that said 

5 constellation comprises a plurality of inner signals, and 
a plurality of outer signals located farther from the 
origin than said inner signals, in that one bit of said 
digital data determines whether any of said plurality of 
signal points will be drawn from said outer signals, and 

10 in that if an outer signal will be drawn, at least one 
other bit of said digital data determines which of said 
plurality of signal points will be an outer signal point. 

49. A method according to Claim 48, further character- 
ised in that there are Z t said signal points, said 
digital data comprises at least t+1 bits, there are S said 
inner signals and 2 _t S said outer signals, and t said bits 

5 determine which of said plurality of signal points will 
be an outer signal point. 

50. A method according to Claims 48 or 49, further 
characterised in that said signals of said constellation 
are arranged on a rectangular grid. 
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51. A method according to Claims 48 to 50, further . 
characterised in that said constellation comprises quad- 
ruplets each having four said signals, the signals 
belonging to each said quadruplet being located at the 
same distance from the origin but separated by 90° 
intervals about the origin of a signal plane, and at least 
two of said bits are quadrantally differentially encoded. 

52. A method according to Claim 49, further character- 
ised in that t=l. 

53. A method according to Claim 52, further character- 
ised in that said block comprises 2N+1 said bits and S 

is 2 N . 

54. A method according to Claim 53, further character- 
ised in that N of said bits determine which inner signal 
is drawn. 

55. A method according to Claim 49, further character- 
ised in that t is 2. 

56. A method according to Claim 55, further character- 
ised in that said block comprises 4N + 1 bits and S is 2 N , 

N being an integer. 

57. . A method according to Claim 55, further character- 
ised in that said block* compri ses 4N + 3 bits and S is 
1.5x2 , N being an integer. 

58. A method according to Claim 56, further character- 
ised in that N-2 of said bits determine which said outer 
signal is drawn and in that N of said bits determine 
which inner signal is drawn. 

59. A method according to any of Claims 53, 54, 56, 57 
or 58, further characterised in that N is 4. 

60. Apparatus for sending digital data over a band- 
limited channel, characterised in that said apparatus 
comprises a code word selector for selecting code words 
corresponding to a plurality of modulation signal points 
drawn from a constellation of available signals, said 
code word selector being adapted to select a said code 
word from an available set of said code words on the basis 
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of. a block of said digital data, the code words belonging 
to said available set for said block being Independent of 
said signal points corresponding to the code word selected 
for any other said block, and said constellation comprising 
groups having equal numbers of said signals, and in that 
said apparatus Includes means for determining the group 
from which at least one said signal point for said block 
1s drawn in dependence upon the group from which at least 
one other said signal point for said block is drawn. 

61. Apparatus according to Claim 60, wherein said 
groups each comprise subsets having equal numbers of said 
signals, said apparatus being further characterised in 
that it comprises subset selector means adapted to select 
the subset from which at least one said signal point for 
said block is drawn in dependence upon the subset from 
which at least one other said signal point for said block 
is drawn. 

62. Apparatus according to Claim 61, further character- 
ised in that said subset selector means is adapted to 
determine said subsets from which said signal points for 
said block are drawn on the basis of a state-transition 
trellis for said block. 

63. Apparatus according to Claim 61, further character- 
ised in that said subset selector means is adapted to . 
determine the subsets and the groups from which said 
signal points for said block are drawn based upon a 
Hamming code applied to at least one of said bits. 

64. Apparatus according to Claim 61, wherein said sub- 
sets each comprise classes having equal numbers of said 
signals, said apparatus being further characterised in 
that it includes class selector means adapted to select 
said class from which at least one signal point for said 
block is drawn in dependence upon the class from which at 
least one other said signal point for said block is drawn. 
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65. Apparatus according to Claim 64, further character- 
ised in that said class selector means is adapted to 
determine said classes from which said signal points for 
said block are drawn based upon a Hamming code applied to 
at least one of said bits. 

66. Apparatus according to Claim 64, wherein said 
classes each comprise subclasses having equal numbers of 
said signals, said apparatus being further characterised 
in that it includes subclass selector means adapted to 
select said subclass from which at least one signal point 
for said block is drawn in dependence upon the subclass 
from which at least one other said signal point for said 
block is drawn. 

67. Apparatus according to Claim 66, wherein said sub- 
class selector means is adapted to determine said sub- 
classes from which said signal points for said block are 
drawn based upon a Golay code applied to at least one of 
said bits. 

68. Apparatus according to any of Claims 60 to 67, 
characterised in that it further comprises means for 
selecting at least one said signal point of said block 
on the 'basis of less than all said digital data in said 
block. 

69. Decoding apparatus characterised in that it is 
adapted to operate in conjunction with apparatus 
according to any of Claims 60 to 68 to decode digital 
data sent over a band-limited channel, and in that said 
decoder includes decider means adapted to decide which 
code word was sent, said decider means being adapted to 
operate on a maximum likelihood sequence estimation in 
accordance with the Viterbi algorithm. 

70. Decoding apparatus characterised in that it is 
adapted to operate in conjunction with apparatus 
according to any of Claims 60 to 68 to decode digital 
data sent over a band-limited channel, and in that said 
decoder includes means adapted to make tentative 
decisions about which signal point was sent prior to 



01 22805 

11 

final decoding of all of the received signal points for a 
block, and in that said decoder includes adaptive control 
circuitry arranged to be responsive to said tentative 
deci si on . 

71. Decoding apparatus characterised in that it is 
adapted to operate in conjunction with apparatus 
according to any of Claims 60 to 68 to decode digital 
data sent over a band-limited channel, and in that said 

5 apparatus includes means adapted to decide which said 

code word was sent, all said signal points for each said 
code word being drawn from the same said group, by first 
making a separate tentative decision based on code words 
whose signal points are drawn from each of said groups, 

10 and thereafter making a final decision based on said 
separate tentative decisions. 

72. Decoding apparatus characterised in that it is 
adapted to operate in conjunction with apparatus 
according to any of Claims 60 to 68 to decode digital 
data sent over a band-limited channel, and in that said 

5 apparatus includes decider means adapted to decide which 
said code word was sent, said digital data comprising 
bits and the selection of said signal points for a block 
depending on a single-parity-check code based on at least 
one of said bits, which decider means includes first means 

10 for making a tentative decision as to each signal point 
in said code word without regard to whether said parity 
check is satisfied, and second means responsive to said 
parity check and adapted to accept said tentative decision 
as the final decision either without change if said parity 

15 check is satisfied or after changing the least reliable 
one of said tentative decisions if said parity check is 
not satisfied. 

73. Apparatus for sanding a block of digital data bits 
over a band-limited channel, said apparatus being 
characterised in that it comprises means for drawing a 
plurality of modulation signal points from a two- 
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dimensional constellation of available signals which 
comprises a plurality of inner signals and a plurality 
of outer signals located further from the origin that 
said inner signals, and in that said apparatus comprises 

5 means responsive to one bit of said digital data for 
determining whether any of said plurality of signal 
points will be drawn from said outer signals, and in 
that said apparatus includes means for determining on 
the basis of at least one other bit of said digital 

10 data, if an outer signal will be drawn, which of said 

plurality of signal points will be an outer signal point. 
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